/* 

给定一个整数数组 a，其中1 ≤ a[i] ≤ n （n为数组长度）, 其中有些元素出现两次而其他元素出现一次。

找到所有出现两次的元素。

你可以不用到任何额外空间并在O(n)时间复杂度内解决这个问题吗？

示例：

输入:
[4,3,2,7,8,2,3,1]

输出:
[2,3]

来源：力扣（LeetCode）
链接：https://leetcode-cn.com/problems/find-all-duplicates-in-an-array
著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。

*/

/**
 * @param {number[]} nums
 * @return {number[]}
 */
// 利用 1 ≤ a[i] ≤ n 这一条件，优雅实现 原地哈希 巧用索引当为值
// 题解：https://leetcode-cn.com/problems/find-all-duplicates-in-an-array/solution/you-ya-shi-xian-yuan-di-ha-xi-qiao-yong-p8p43/
var findDuplicates = function (nums) {
    const res = [];

    for (let num of nums) {
        // 关键代码
        num = Math.abs(num);
        if (nums[num - 1] < 0) {
            res.push(num);
        } else {
            nums[num - 1] *= -1;
        }
    }

    return res;
};